**![Logo

Description automatically generated](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHkAAAB1CAMAAABd5r4AAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAJDUExURf///97KrcCXXb6WXL+XXNO2i/39/Pz6+Mytf9G0i/j18EVZZgdBaglCaghCaiRQbL2WXMCZYLaUZRVHbbuUXs6whi9NarSTaMCXXJiBY1pgar+XXQNAaAM8ZgM9Z/j4+QY6ZklJguHj6baSXx9Hcfn5+sytgf7+/s7T2YiVqvLr35mDarzCzvv7+8SaXgVAajtafRdHbqmvwIORqAA9aThMecGZYAM+aufp7a6OYrO3w19ukMXK09nDovLy9QY/aAdBabqUXi9OeJylugRBafPz93KCnwQ+Z8nN2dLU3ePm65ijtExsigZAaRlJcBVFbWRzigNBaQhBaQdCagA8Z4aPoyFIdAE9Zr6WW4GPp//+/pV+Zy9OdwZBagU9ZiZPd/Hz9b+XXgM7ahtGaRM9bfb39wI3ZAdAaCBHariSXKCEXgZBaUJVaL+WWwhAabyUXL2VXAQ/aAA0Z3CBmvz8/QI/afPz9Yl2Y35vZL6XXYKLo494ZFdebJumugA2ZQdAauXn7Orh1wExZcCdbJ6DYTJMaGx7l3BpZAE4ZO7v87mTXOXWxIKQqJWkuARAaNve5AdAabWQXTdQZ9W9mAQ8Zr+WXAFAadPV3UdggBVIdv7+/wY8ZyVLa4SSpQAzZwA/amx9k/T19/n29D5ZfQE+avv7/czO2tG4mQY4ZKaIYbK3yiFIatze5XB7ml1uktnCoY59a8moeOrdywVCau7j1drEpFZha+/l2A9CatzGpw1CasajcQ5Eav///v79/Pfy6wAAAAAd6RIAAADBdFJOU////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wCINFSNAAAACXBIWXMAACHVAAAh1QEEnLSdAAAKWklEQVRoQ+1bPatkxxGdDcwL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) San Francisco Bay University**

**EE488 - Computer Architecture**

**Homework Assignment #6**

**Due day: 4/10/2023**

**Name: Simon Gezae ID: 19830**

**Instruction:**

1. **Push the answer sheet to GitHub in word file**
2. **Overdue homework submission could not be accepted.**
3. **Takes academic honesty and integrity seriously (Zero Tolerance of Cheating & Plagiarism)**
4. Write the design module in RTL level to implement"Carry Lookahead" addition for 8-bits adder including carry-in bit, and then verify it by the testbench.

Design:

module cla8(input [7:0] a, b,

input cin,

output [7:0] sum,

output cout);

wire carry\_mid;

cla4 u1 (a[3:0],b[3:0],cin,sum[3:0],carry\_mid); //cout of the first half

cla4 u2 (a[7:4],b[7:4],carry\_mid,sum[7:4],cout);//is used as cin in the next

endmodule

module cla4(input [3:0] a, b,

input cin,

output [3:0] sum,

output cout);

wire [3:0] c, p, g;

assign p = a^b;

assign g = a&b;

assign c[0] = cin;

assign c[1]= g[0] | (p[0]&c[0]); // g[0] = a[0]&b[0] p[0] = a[0]&b[0]

assign c[2]= g[1] | (p[1]&g[0]) | p[1]&p[0]&c[0];

assign c[3]= g[2] | (p[2]&g[1]) | p[2]&p[1]&g[0] | p[2]&p[1]&p[0]&c[0];

assign cout= g[3] | (p[3]&g[2]) | p[3]&p[2]&g[1] | p[3]&p[2]&p[1]&g[0] | p[3]&p[2]&p[1]&p[0]&c[0];

assign sum=p^c; //p=(a^b) sum=a^b^c

endmodule

Testbench:

module tb;

reg [7:0] a, b;

reg cin;

wire [7:0] sum;

wire cout;

integer i;

cla8 u3 (a,b,cin,sum,cout);

initial begin

$display("A\t\tB\t\tCin\tSum\t\tCout");

$monitor("%b\t%b\t%b\t%b\t%b", a,b,cin,sum,cout);

for (i=508; i<512; i=i+1)begin

{a,b,cin} = i;

#2;

end

#2 a = 8'b0; b = 8'b0; cin = 8'b0;

#2 a = 8'b1111\_1111; b = 8'b1111\_1111; cin = 8'b0;

#5 $finish;

end

endmodule

Edaplayground: <https://edaplayground.com/x/PHYp>

Question 1 method 2

Design:

module CLAhead8(input [7:0] a,

input [7:0] b,

input cin,

output [7:0] sum,

output cout);

wire [8:0] p, g;

wire [7:0] c;

assign p = a^b;

assign g = a&b;

assign c[0] = cin;

genvar gv;

generate

for (gv = 1; gv < 8; gv = gv + 1) begin : lag

assign c[gv] = g[gv] | p[gv] & c[gv - 1];

end

endgenerate

assign sum = a + b + cin;

assign cout = g[7] | p[7] & c[7]; // cout == ci+1 = gi+pi&ci

endmodule

Testbench:

module TB();

reg [7:0] a, b;

reg cin;

wire [7:0] sum;

wire cout;

CLAhead8 U1 (.a(a), .b(b), .cin(cin), .sum(sum), .cout(cout));

initial begin

$display("A\t\tB\t\tCin\tSum\t\tCout");

$monitor("%b\t%b\t%b\t%b\t%b", a,b,cin,sum,cout);

a = 8'b00000000; b = 8'b00000000; cin = 0;

#1 a = 8'b00000001; b = 8'b00000001; cin = 0;

#1 a = 8'b00000011; b = 8'b00000011; cin = 0;

#1 a = 8'b00111111; b = 8'b00111111; cin = 0;

#1 a = 8'b01111111; b = 8'b01111111; cin = 1;

#1 a = 8'b11111111; b = 8'b11111111; cin = 0;

#1 a = 8'b11111111; b = 8'b11111111; cin = 1;

#1 $finish();

end

endmodule

Edaplayground: <https://www.edaplayground.com/x/vhM8>

1. Write a Verilog module to design 8-bits ALU based on the following opcodes. In the summation operation, the submodule instantiated by "generate" block in the top module should implement "Carry Lookahead". And then verify your design by the testbench.

|  |  |
| --- | --- |
| Opcode | Operations |
| 0000 | Out = A + B |
| 0001 | Out = A - B |
| 0010 | Out = A \* B |
| 0011 | Out = A / B |
| 0100 | Out = A << 1 |
| 0101 | Out = A >> 1 |
| 0110 | Out = A rotated left by 1 |
| 0111 | Out = A rotated right by 1 |
| 1000 | Out = A and B |
| 1001 | Out = A or B |
| 1010 | Out = A xor B |
| 1011 | Out = A nor B |
| 1100 | Out = A nand B |
| 1101 | Out = A xnor B |
| 1110 | Out = 1 if A>B else 0 |
| 1111 | Out = 1 if A=B else 0 |

Design:

module ALU(

input [7:0] a,

input [7:0] b,

input [3:0] opcode,

output reg [15:0] out);

//using generate

wire [7:0] pc;

genvar i;

generate

wire [7:0] gc;

assign gc = 1'b0;

for (i = 0; i < 8; i = i + 1) begin : cla

assign gc[i] = a[i] & b[i];

end

for (i = 1; i < 8; i = i + 1) begin : p

assign pc[i] = a[i-1] | b[i-1];

end

assign pc[0] = 1'b0;

endgenerate

always @(\*) begin

case(opcode)

4'b0000: out = a + b;

4'b0001: out = a - b;

4'b0010: out = a \* b;

4'b0011: out = a / b;

4'b0100: out = a << 1;

4'b0101: out = a >> 1;

4'b0110: out = {a[6:0], a[7]};

4'b0111: out = {a[0], a[7:1]};

4'b1000: out = a & b;

4'b1001: out = a | b;

4'b1010: out = a ^ b;

4'b1011: out = ~(a | b);

4'b1100: out = ~(a & b);

4'b1101: out = ~(a ^ b);

4'b1110: out = (a > b) ? 1'b1 : 1'b0;

4'b1111: out = (a == b) ? 1'b1 : 1'b0;

default: out = 8'bx;

endcase

end

endmodule

Testbench:

module TB;

reg [7:0] A;

reg [7:0] B;

reg [3:0] opcode;

wire [15:0] out;

ALU U1 (.a(A),

.b(B),

.opcode(opcode),

.out(out));

initial begin

A = 8'b11010101; B = 8'b00101010; opcode = 4'b0000;

#2 $display("A = %b, B=%b, out", A, B);

#2 $display("A + B = %b", out[7:0]);

opcode = 4'b0001;

#2 $display("A - B = %b", out[7:0]);

opcode = 4'b0010;

#2 $display("A \* B = %b", out);

opcode = 4'b0011;

#2 $display("A / B = %b", out);

opcode = 4'b0100;

#2 $display("A << 1 = %b", out[7:0]);

opcode = 4'b0101;

#2 $display("A >> 1 = %b", out[7:0]);

opcode = 4'b0110;

#2 $display("ROL = %b", out[7:0]);

opcode = 4'b0111;

#2 $display("ROR = %b", out[7:0]);

opcode = 4'b1000;

#2 $display("A & B = %b", out[7:0]);

opcode = 4'b1001;

#2 $display("A | B = %b", out[7:0]);

opcode = 4'b1010;

#2 $display("A ^ B = %b", out[7:0]);

opcode = 4'b1011;

#2 $display("~(A | B) = %b", out[7:0]);

opcode = 4'b1100;

#2 $display("~(A & B) = %b", out[7:0]);

opcode = 4'b1101;

#2 $display("~(A ^ B) = %b", out[7:0]);

opcode = 4'b1110;

#2 $display("A > B = %b",out[7:0]);

opcode = 4'b1111;

#2 $display("A == B = %b", out[7:0]);

end

endmodule

Edaplayground: <https://www.edaplayground.com/x/KR7r>